

# Microcontroladores

**TIMER** 





# Timer

Contagem de Tempo





### Para que serve a contagem de tempo?







### Timer no ATmega328P

- O microcontrolador ATmega328P possui três unidades de Timer/Contador;
  - TIMER 0: 8 bits;
  - o TIMER 1: 16 bits;
  - TIMER 2: 8 bits;







# Modos de Operação





# Overflow





#### **Como Funciona?**

- A contagem é feita de forma crescente;
- No caso do TIMER O, quando a contagem passa de 255->0, ocorre o estouro (OVERFLOW). Dessa forma, o BIT TOVO, presente no registrador TIFR, é setado. Caso a interrupção esteja habilitada, ela é gerada.;

$$t_{estouro} = \frac{(TOP+1) \times prescaler}{f_{osc}}$$

TOP é o valor máximo de contagem,  $f_{osc}$  é a frequência do clock e o prescaler é o divisor dessa frequência.





# Comparação (CTC)





#### **Como Funciona?**

- No modo CTC (Clear timer on compare Limpeza do contador na igualdade de comparação), o registrador OCRnA é utilizado como referência (TOP) na contagem;
- Dessa forma, quando o registrador de contagem:
  TCNTn = OCRnA ou OCRnB, a contagem é reiniciada.







# Registradores – TIMER O





### Timer/Counter Control Register (TCCR0A E TCCR0B)

- Registrador de Controle;
- Permite a configuração de clock + prescaler;

|        | 7     | 6     | 5     | 4 | 3     | 2    | 1    | 0    |
|--------|-------|-------|-------|---|-------|------|------|------|
| TCCR0B | FOC0A | FOC0B | (845) | - | WGM02 | CS02 | CS01 | CS00 |
|        | E     | E     | L     | L | L/E   | L/E  | L/E  | L/E  |
|        | 0     | 0     | 0     | 0 | 0     | 0    | 0    | 0    |

- Os bits CS00, CS01 e CS02 fazem a seleção da fonte de clock;
- O bit WGM02, junto com os bits WGM00 e WGM01 (PRESENTES NO TCCR0A) definem o modo de operação do TIMER;

## Inatel

### **E209 – Sistemas Microcontrolados e Microprocessados**



| CS02 | CS01 | CS00 | Descrição                                               |  |  |
|------|------|------|---------------------------------------------------------|--|--|
| 0    | 0    | 0    | Sem fonte de clock (TC0 parado).                        |  |  |
| 0    | 0    | 1    | clock/1 (prescaler=1) - sem prescaler.                  |  |  |
| 0    | 1    | 0    | clock/8 (prescaler = 8).                                |  |  |
| 0    | 1    | 1    | clock/64 (prescaler = 64).                              |  |  |
| 1    | 0    | 0    | clock/256 (prescaler = 256).                            |  |  |
| 1    | 0    | 1    | clock/1024 (prescaler = 1024).                          |  |  |
| 1    | 1    | 0    | clock externo no pino T0. Contagem na borda de descida. |  |  |
| 1    | 1    | 1    | clock externo no pino T0. Contagem na borda de subida.  |  |  |



#### **E209 – Sistemas Microcontrolados e Microprocessados**



| Bit    | 7      | 6      | 5      | 4      | 3 | 2 | 1     | 0     |
|--------|--------|--------|--------|--------|---|---|-------|-------|
|        | COM0A1 | COM0A0 | COM0B1 | COM0B0 |   |   | WGM01 | WGM00 |
| Access | R/W    | R/W    | R/W    | R/W    |   |   | R/W   | R/W   |
| Reset  | 0      | 0      | 0      | 0      |   |   | 0     | 0     |

| Modo | WGM02 | WGM01 | WGM00 | Modo de<br>Operação<br>TC | ТОР   | Atualização<br>de OCR0A<br>no valor: | Sinalização<br>do bit TOV0<br>no valor: |
|------|-------|-------|-------|---------------------------|-------|--------------------------------------|-----------------------------------------|
| 0    | 0     | 0     | 0     | Normal                    | 0xFF  | Imediata                             | 0xFF                                    |
| 1    | 0     | 0     | 1     | PWM com fase corrigida    | 0xFF  | 0xFF                                 | 0x00                                    |
| 2    | 0     | 1     | 0     | CTC                       | OCR0A | Imediata                             | 0xFF                                    |
| 3    | 0     | 1     | 1     | PWM rápido                | 0xFF  | 0x00                                 | 0xFF                                    |
| 4    | 1     | 0     | 0     | Reservado                 |       | -                                    |                                         |
| 5    | 1     | 0     | 1     | PWM com fase corrigida    | OCR0A | OCR0A                                | 0x00                                    |
| 6    | 1     | 1     | 0     | Reservado                 | 948   | (=)                                  | 24                                      |
| 7    | 1     | 1     | 1     | PWM rápido                | OCR0A | 0x00                                 | OCR0A                                   |





### TC0 Interrupt Mask Register (TIMSK0)

Registrador reponsável por habilitar as interrupções;

| 242    | 7   | 6 | 5 | 4 | 3 | 2      | 1      | 0     |
|--------|-----|---|---|---|---|--------|--------|-------|
| TIMSK0 | 170 | - | - | - | - | OCIE0B | OCIE0A | TOIE0 |
|        | L   | L | L | L | L | L/E    | L/E    | L/E   |
|        | 0   | 0 | 0 | 0 | 0 | 0      | 0      | 0     |

- A escrita '1' no bit OCIEOB, habilita a interrupção do TCO na igualdade de comparação com registrador OCROB;
- A escrita '1' no bit OCIEOA, habilita a interrupção do TCO na igualdade de comparação com registrador OCROA;
- A escrita '1' no bit TOIEO, habilita a interrupção do TCO por OVERFLOW(255->0);

## Inatel



Configuração dos registradores para trabalhar com comparação

- Configurar o modo de operação do TIMER e o divisor do clock: TCCROA e TCCROB;
- Configurar o valor máximo de contagem: OCROA;
- Habilitar a interrupção do comparador desejado: TIMSKO;
- Habilitar a interrupção global do microcontrolador: sei();





### Rotina de Interrupção (ISR)

### Inatel



# Obrigado!

